DEPLOYED AGENT USED IN THE INSTALLATION AND 

MAINTENANCE OF SOFTWARE 

BACKGROUND 

The present invention concerns deployment of software to desktop 
computers and pertains particularly to a deployed agent used in the 
installation and maintenance of software. 

They are many ways computers linked together in a local area 
network (LAN) can run applications. Applications can be run from a 
central location such as a server. Alternatively, applications can be 
installed on individual computers. Each method has benefits and 
drawbacks. 

For example, when applications are run from a central server, this 
greatly simplifies the maintenance of the applications. However, one 
drawback of running applications from a central server is that this requires 
a lot of network bandwidth. Also, because of lost network connections, 
applications can fail intermittently. 

When applications are rim on individual computers, this reduces the 
amount of network bandwidth required. Also, lost network connections do 
not necessarily lead to application failures on individual computers. 
However, maintaining applications on individual computers is more 
complicated. It is difficult to ensure sufficient access and privilege to 
manage, from a central location, different applications residing in many 
. computers. 
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"^Alternated software distribution system can provide a solution to 
some of the aforementioned proBTSins^However, depending upon how this is 
done, it can result in many additional problem! 
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SUMMARY OF THE INVENTION 
In accordance with the preferred embodiment of the present 
invention, a managing computer manages applications residing on a 
managed computer. An agent is forwarded from the managing computer to 
5 the managed computer. The agent runs on the managed computer. The 
agent maintains specified applications residing on the managed computer. 
The agent also performs requests made by the managing computer. 

In the preferred embodiment, the agent detects lost network 
connections. The agent also monitors network connection speed between 
10 the managed computer and the managing computer to determine a best 
time to transfer data from the managing computer to the managed 
computer. In one embodiment, the agent stops all network applications on 
the managed computer when the network connection speed is below a 
predetermined threshold. The agent also can monitor the integrity of 
15 specified applications within the managed computer to ascertain when 
repair is needed. The agent also downloads and installs specified 
applications from the managing computer to the managed computer. 

The agent monitors communications from the managed computer to 
determine when the managed computer desires the agent to take a 
20 requested action. The requested action can be, for example, to uninstall an 
application, to stop an application or to upgrade an application. 

The present invention greatly simplifies the maintenance, from a 
central location, of applications distributed on many different computer 
systems. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
Figure 1 illustrates distribution of agents from a managing computer 

to managed computers in accordance with a preferred embodiment of the 

present invention. 

Figure 2 illustrates information flow between agents located within 

managed computers and a managing computer in accordance with a 

preferred embodiment of the present invention. 

Figure 3 shows a block diagram of an agent used for software 

distribution and maintenance in accordance with a preferred embodiment of 

the present invention. 
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DESCRIPTION OF THE PREFERRED EMBODIMENT 
Figure 1 illustrates distribution of an agent 10 from a managing 
computer 20 to a managed computer 21, a managed computer 22, a 
managed computer 23 and a managed computer 24. Agent 10 is used for 
5 software distribution and maintenance in accordance with a preferred 
embodiment of the present invention. 

Agent 10 is "pushed" or "pulled" from managing computer 20 to 
managed computers 21 through 24. Agent 10 then installs itself on each of 
managed computers 21 through 24 based on the configuration of agent 10 
10 and the platform on which managed computers 21 through 24 run. 

^br^Qxample, managed computers 21 through 24 are on a list of 
specified attendecha^id unattended computers targeted by managing 
computer 20. If any of maii&gedcomputers 21 through 24 are shut off when 
managing computer 20 will periodicalljrs^iecks and pushes the agent to 
15 targeted computer as soon as managing compiifei^^O detects the managed 
computer is turned on. ^ 

Figure 2 shows agent 10 residing, after installation, within all of 
managed computers 21 through 24. Agent 10 performs self-maintenance 
within managed computers 21 through 24. In addition, depending upon the 
20 capability and configuration of agent 10, agent 10 installs and maintains 
specified applications and agents within each of managed computers 21 
through 24. Maintenance includes, for example, making updates to the 
specified applications when new versions are available on the managing 
computer. Agent 10 also performs requests issued from managing 
25 computer 21 through 24. 
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In addition, agent 10 detects and provides remedies of abnormal 
conditions within managed computers 21 through 24. For example, agent 10 
detects lost network connections. When a lost network connection is 
detected, agent 10 stops network applications to reduce impact on network 
performance. Agent 10 also detects integrity problems and performs 
necessary repairs. 

Figure 3 is a block diagram of agent 10 after installation. Agent 10 
includes a network speed sensor 17, an integrity sensor 16 and an action 
sensor 15 all interfacing to a main engine 11, as shown. Main engine 11 
includes perform action request logic 12, repairing logic 13 and scheduling 
logic 14. 

Network speed sensor 12 signals main engine 11 when to pull down 
application files, and when to start and stop an application agent. Integrity 
sensor 16 signals main engine 10 to repair a particular agent and/or 
applications. Action sensor 15 signals main engine 11 when an action is 
requested. 

Table 1 below lists simplified pseudo code that illustrates functionality 
of network speed sensor 17: 
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Table 1 

/***Monitor the connection speed between client (managed 
computer) and server. ***/ 

5 CheckNetworkThreshold (Threshold Bit/Sec) 

{ 

While ( not terminate) 

{ 

Mark StartTime 

10 Read X number of bytes from Compress file on server. 

Mark EndTime. 

AccessRate = (X * 8 bits) / EndTime - StartTime 
If (AccessRate > Threshold) 

Set NetworkThreshold Event below Specified Threshold. 
15 Wait For Acknowledgment. 

Else 

Sleep for number of sees 
Continue 

} 

20 Quit. 
} 

Table 2 below lists simplified pseudo code that illustrates functionality 
of integrity sensor 16: 
25 Table 2 



/***Detect if any specified integrity has been violated, such 
as a missing file, a registry deleted, an application 
uninstalled***/ 



30 



CheckFor Integrity ( List of Item to check) 
{ 

While ( not terminate) 
{ 

35 For ( n = Firstltem to Lastltem) 

{ 

If ( nltem not Exist) 
{ 

Set Integrity Event 
40 Wait For Acknowledgment. 

} 

} 

Sleep for number of sees. 

} 

45 } 



Hewlett-Packard Company 



Docket Number 10992824-1 



8 



*3 ? 

iti ? 

p= - 

b 



S 3 

d 

is s 
^=1 



Table 3 below lists simplified pseudo code that illustrates functionality 
of action sensor 15: 

Table 3 

5 

/*** Monitors if any action has been issued.***/ 

CheckForActionRequestO 
{ 

10 While ( not Terminate) 

{ 

If ( Receive Action request notification) 

Case Action request: 

{ 

15 Uninstall: 

Set Event Uninstall 
Quit. 

Stop an application: 

Set Event Stop application X. 
20 Upgrade: 

Set Event Upgrade. 



m } 

III Sleep for n sees 

5 25 } 
i:i Quit. 

h 

) 

30 Table 4 below lists simplified pseudo code that illustrates functionality 

of main engine 11: 
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Table 4 

/*** Monitors a set of events and perform task accordingly***/ 

While ( not Terminate) 
5 { 

If (NetworkThreshold Event is set) 
{ 

Stop all network applications. 
Reset NetworkThreshold Event} 

10 } 

If ( Integrity Event set) 

{ 

Perform repairing process 
Reset Integrity Event 

15 } 

If ( ActionRequest Event set) 
{ 

Case ( ActionRequest Event) 
Uninstall Event Set: 
20 Stop all applications 

Perform Uninstall. 
Quit. 

StopApplication Event Set: 
Stop specified application. 
|jj 25 Reset ActionRequest Events. 

\\\ Upgrade Event Set: 

jlj Stop All applications. 

£ I PerformUpgrade . 

H 5 j Reset Upgrade Event. 

30 } 

Perform Scheduling, this process determines start or stop an 
application. 

Sleep for n sees. 
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The foregoing discussion discloses and describes merely exemplary 
methods and embodiments of the present invention. As will be understood by 
those familiar with the art, the invention may be embodied in other specific 
forms without departing from the spirit or essential characteristics thereof. 
40 Accordingly, the disclosure of the present invention is intended to be 

illustrative, but not limiting, of the scope of the invention, which is set forth 
in the following claims. 
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